home *** CD-ROM | disk | FTP | other *** search
/ Revista do CD-ROM 101 / CD-ROM 101.iso / compl / maya5ple / Install_MayaPLE5_English.exe / Maya / Data1.cab / distance2Pts.mel < prev    next >
Encoding:
Text File  |  2003-07-17  |  1.4 KB  |  39 lines

  1. // Copyright (C) 1997-2002 Alias|Wavefront,
  2. // a division of Silicon Graphics Limited.
  3. //
  4. // The information in this file is provided for the exclusive use of the
  5. // licensees of Alias|Wavefront.  Such users have the right to use, modify,
  6. // and incorporate this code into other products for purposes authorized
  7. // by the Alias|Wavefront license agreement, without fee.
  8. //
  9. // ALIAS|WAVEFRONT DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
  10. // INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
  11. // EVENT SHALL ALIAS|WAVEFRONT BE LIABLE FOR ANY SPECIAL, INDIRECT OR
  12. // CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
  13. // DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  14. // TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  15. // PERFORMANCE OF THIS SOFTWARE.
  16. //
  17. //
  18. //    Description:
  19. //        Returns the distance between two 3D points.
  20. //
  21. global proc float distance2Pts( float $p1[], float $p2[] )
  22. {
  23.     if( size($p1) != 3 )
  24.         warning("distance2Pts(): You must give a float array of 3 values as the 1st argument\n");
  25.     if( size($p2) != 3 )
  26.         warning("distance2Pts(): You must give a float array of 3 values as the 2nd argument\n");
  27.  
  28.     float $distance;
  29.     float $v[3];
  30.     $v[0] = $p1[0] - $p2[0];
  31.     $v[1] = $p1[1] - $p2[1];
  32.     $v[2] = $p1[2] - $p2[2];
  33.     $distance = $v[0]*$v[0] + $v[1]*$v[1] + $v[2]*$v[2];
  34.     $distance = sqrt( $distance );
  35.  
  36.     return $distance;
  37. }
  38.  
  39.